//package com.example.common.customer.server.interceptor;
//
//import com.baomidou.mybatisplus.extension.handlers.AbstractSqlParserHandler;
//import com.example.common.utils.ArrayUtil;
//import org.apache.ibatis.mapping.MappedStatement;
//import org.apache.ibatis.mapping.SqlCommandType;
//import org.apache.ibatis.plugin.*;
//
//import java.lang.reflect.Field;
//import java.util.Date;
//import java.util.Map;
//import java.util.Objects;
//import java.util.Properties;
//import java.util.concurrent.Executor;
//
////  拦截未成功    mybatis-plus  新增 修改字段时  创建时间  修改时间 自动插入
//@Intercepts(value = {@Signature(type = Executor.class, method = "update", args = {MappedStatement.class, Object.class})})
//public class SqlInterceptor extends AbstractSqlParserHandler implements Interceptor {
//
//    /**
//     * 创建时间
//     */
//    private static final String CREATE_TIME = "createTime";
//    /**
//     * 更新时间
//     */
//    private static final String UPDATE_TIME = "updateTime";
//
//    @Override
//    public Object intercept(Invocation invocation) throws Throwable {
//        MappedStatement mappedStatement = (MappedStatement) invocation.getArgs()[0];
//        // SQL操作命令
//        SqlCommandType sqlCommandType = mappedStatement.getSqlCommandType();
//        // 获取新增或修改的对象参数
//        Object parameter = invocation.getArgs()[1];
//        // 获取对象中所有的私有成员变量（对应表字段）
//        Field[] declaredFields = parameter.getClass().getDeclaredFields();
//        if (parameter.getClass().getSuperclass() != null) {
//            Field[] superField = parameter.getClass().getSuperclass().getDeclaredFields();
//            declaredFields = ArrayUtil.addAll(declaredFields, superField);
//        }
//        // mybatis plus判断
//        boolean plus = parameter.getClass().getDeclaredFields().length == 1 && parameter.getClass().getDeclaredFields()[0].getName().equals("serialVersionUID");
//
//        //兼容mybatis plus
//        if (plus) {
//            Map<String, Object> updateParam = (Map<String, Object>) parameter;
//            Class<?> updateParamType = updateParam.get("param1").getClass();
//            declaredFields = updateParamType.getDeclaredFields();
//            if (updateParamType.getSuperclass() != null) {
//                Field[] superField = updateParamType.getSuperclass().getDeclaredFields();
//                declaredFields = ArrayUtil.addAll(declaredFields, superField);
//            }
//        }
//        String fieldName = null;
//        for (Field field : declaredFields) {
//            fieldName = field.getName();
//            if (Objects.equals(CREATE_TIME, fieldName)) {
//                if (SqlCommandType.INSERT.equals(sqlCommandType)) {
//                    field.setAccessible(true);
//                    field.set(parameter, new Date());
////                    field.set(parameter, new Timestamp(System.currentTimeMillis()));
//                }
//            }
//            if (Objects.equals(UPDATE_TIME, fieldName)) {
//                if (SqlCommandType.INSERT.equals(sqlCommandType) || SqlCommandType.UPDATE.equals(sqlCommandType)) {
//                    field.setAccessible(true);
//                    //兼容mybatis plus的update
//                    if (plus) {
//                        Map<String, Object> updateParam = (Map<String, Object>) parameter;
//                        field.set(updateParam.get("param1"), new Date());
////                        field.set(updateParam.get("param1"), new Timestamp(System.currentTimeMillis()));
//                    } else {
//                        field.set(parameter, new Date());
////                        field.set(parameter, new Timestamp(System.currentTimeMillis()));
//                    }
//                }
//            }
//        }
//        return invocation.proceed();
//    }
//
//    @Override
//    public Object plugin(Object target) {
//        if (target instanceof Executor) {
//            return Plugin.wrap(target, this);
//        }
//        return target;
//    }
//
//    @Override
//    public void setProperties(Properties properties) {
//    }
//}
